package day_7_16;

public class Main3 {
    /**
     * 383. 赎金信
     * https://leetcode.cn/problems/ransom-note/description/?envType=study-plan-v2&envId=top-interview-150
     */
    public boolean canConstruct(String ransomNote, String magazine) {
        if(ransomNote.length() > magazine.length()) {
            return false;
        }
        int[] cut = new int[26];
        // 将 magazine 中的值都放进哈希表中
        for(int i = 0;i < magazine.length();i++) {
            cut[magazine.charAt(i) - 'a']++;
        }
        // 将 ransomNote 中数值在 哈希表中进行减少，如果出现负数就退出
        for(int i = 0;i < ransomNote.length();i++) {
            if(--cut[ransomNote.charAt(i) - 'a'] < 0) {
                return false;
            }
        }
        return true;
    }
}
